$(function () {
    // 1.1 获取裁剪区域的 DOM 元素
    var $image = $('#image')
    // 1.2 配置选项
    const options = {
        // 纵横比
        aspectRatio: 1,
        // 指定预览区域
        preview: '.img-preview'
    }

    // 1.3 创建裁剪区域
    $image.cropper(options)

    //位上传按钮绑定点击事件
    $('#btnChooseImage').on('click', function () {
        $('#file').click()
    })

    //当用户选择了某一张图片的时候，会自动触发change事件
    $('#file').on('change', function (e) {
        const files = e.target.files

        //把伪数组转化为真正的数组[...files]
        if (Array.from(files).length === 0) {
            return '请选择图片'
        }

        //获取到用户选择的文件
        const file = files[0]
        // 根据选择的文件，创建一个对应的 URL 地址：
        var newImgURL = URL.createObjectURL(file)

        $image.cropper('destroy')      // 销毁旧的裁剪区域
            .attr('src', newImgURL)  // 重新设置图片路径
            .cropper(options)        // 重新初始化裁剪区域

    })

    //为确定按钮啊啊绑定点击事件
    $('#btnUpload').on('click', function() {
        // 1. 要拿到用户裁剪之后的头像
        var dataURL = $image
          .cropper('getCroppedCanvas', {
            // 创建一个 Canvas 画布
            width: 100,
            height: 100
          })
          .toDataURL('image/png') // 将 Canvas 画布上的内容，转化为 base64 格式的字符串
        // 2. 调用接口，把头像上传到服务器
        $.ajax({
          method: 'POST',
          url: '/my/update/avatar',
          data: {
            avatar: dataURL
          },
          success: function(res) {
            if (res.status !== 0) {
              return layer.msg('更换头像失败！')
            }
            layer.msg('更换头像成功！')
            window.parent.getUserInfo()
          }
        })
      })
    // 先销毁旧的裁剪区域，再重新设置图片路径，之后再创建新的裁剪区域：

    // 将裁剪后的图片，输出为 base64 格式的字符串
    // var dataURL = $image
    //     .cropper('getCroppedCanvas', { // 创建一个 Canvas 画布
    //         width: 100,
    //         height: 100
    //     })
    //     .toDataURL('image/png')       // 将 Canvas 画布上的内容，转化为 base64 格式的字符串
})